<!-- 
高阶函数是对其它函数进行操作的函数，它接收函数作为参数或将函数作为返回值输出
函数也是一种数据类型，同样可以作为参数，传递给另外一个参数使用。最典型的就是做回回调函数
 -->
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="jquery.min.js"></script>
    <style>
        div {
            width: 200px;
            height: 200px;
            background-color: pink;
        }
    </style>
</head>


<body>
    <div></div>
    <!-- 高阶函数-函数可以作为参数传递 -->
    <script>
        function fn(a, b, callback) {
            console.log(a + b);
            callback && callback();  //如果callback函数存在就执行callback()函数，否则不执行。
        }
        fn(1, 2, function () {
            console.log('我是最后调用的');
        });

        $('div').animate({ left: 500 }, function () {
            $('div').css('backgroundColor', 'purple')
        })
    </script>
</body>

</html>